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SYSTEM AND METHOD FOR GENERATING. DISTRIBUTING. STORING 
AND PERFORMING MUSICAL WORK FILES 

BACKGROUND OF THE INVENTION 
5 1 . Field of the Invention 

This invention relates generally to Musical Instrument Digital 
Interface (MIDI) technology, and more particularly to a system and 
method for generating, distributing, storing and performing musical 
work files. 

10 

2. Description of the Background Art 

Music is one of the most popular forms of creative expression. 
Accordingly, musical system designers have attempted to provide 
composers with musical tools, such as Musical Instrument Digital 

15 Interface (MIDI) technology and General MIDI, for facilitating the 
creation, distribution, storage and performance of musical works. 

MIDI is an international standard that specifies a hardware 
setup and a software protocol for controlling electronic music 
instruments. The hardware setup is a serial communications 

20 network that runs quickly enough to play very complex music in real 
time. The software protocol is comprehensive and flexible, and 
provides a mechanism for encoding basic note playing, performance 
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expression, sound selection and elaborate modes of tape machine and 
theatrical control. Although MIDI is compact, flexible and lends itself 
to multimedia applications, traditional MIDI equipment is commonly 
acknowledged as far too complex for consumers to handle. Further, 
5 MIDI compositions are system dependent, and thus, for example, 
musical information intended by the composer to represent the 
sounds of a grand piano may be reproduced by a first player system 
as a bass guitar and by a second player system as a flute. 

In response to the complexity and system dependence of MIDI, 

10 music system designers created General MIDI which recommends 
standards and common practices for providing more predictable 
results and a greater ease of use. Thus, musical information intended 
by the composer to represent the sounds of a grand piano will be 
played by all player systems which implement General MIDI as a 

15 grand piano. However, because of several critical limitations 

including a lack of variety, a lack of playing audio samples and poor 
expressive quality, composers have found General MIDI to be 
inhibiting. 

Therefore, a system and method are needed to provide 
20 composers with a musical tool that facilitates generation, distribution, 
storage and performance of musical information without 
compromising composer intention, creativity and sound quality. 
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SUMMARY OF THE INVENTION 
The present invention provides a system and method for 
composing and playing back musical works. The system includes a 
sound bank containing at least one instrument sound, an input device 
5 for receiving music control signals, a sequencer coupled to the input 
device for storing the music control signals, and a work manager 
coupled to the sound bank and to the sequencer for generating a 
musical work file containing the music control signals and at least a 
portion of the sound bank. The system further includes a 

10 synthesizer engine coupled to the input device for processing the 
music control signals based on the instrument sounds contained in 
the sound bank, a mixer coupled to the synthesizer engine for mixing 
effects with the processed music control signals, and a speaker 
system coupled to the mixer for converting the mixed music control 

15 signals to sound. 

The method includes the steps of receiving music control 
signals, receiving at least a portion of a sound bank containing at 
least one instrument sound, and storing the music control signals and 
received sound bank portion as a musical work file. The method 

20 further includes the steps of processing the music control signals 

based on the instrument sounds contained in the sound bank, mixing 
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effects with the processed music control signals, and converting the 
mixed music control signals to sound. 

Because, in addition to the MIDI changes, the work manager 
stores the sound bank to the musical work file, the system and 
5 method provide all the information needed to perform the musical 
piece. Thus, system independence is achieved. That is, unlike 
systems implementing standard MIDI, the system and method 
forward data representing the instrument sounds and topology 
information needed to perform the piece. Unlike systems 

10 implementing General MIDI, the system and method enable creation 
and modification of an infinite variety of custom instrument or non- 
instrument sounds and thus is not limited to a predetermined set of 
128 instruments (plus percussion). Predictable consumer MIDI 
performance, which was hitherto impossible to achieve, is now 

15 rendered certain by this invention. 

It will be further appreciated that since the entire system and 
method is implemented in software, it is possible to maintain any 
number of channels and any number of tracks, but, of course, limited 
by processor speed, system bandwidth and memory availability. 

20 Thus, the system and method may include an equal number of 

channels and tracks so that each channel can be stored on a single 
track. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of a music network system in 
accordance with the present invention; 

FIG. 2 is a block diagram illustrating details of the composer 
server of FIG. 1; 

FIG. 3 is a block diagram illustrating details of the composition 
system of FIG. 2; 

FIG. 4a illustrates a sound editor for a synthetic voice; 

FIG. 4b illustrates a waveform generated by a digital sound 
editor which uses Pulse Code Modulation (PCM) techniques; 

FIG. 4c illustrates a combined sound editor; 

FIG. 4d illustrates a sound editor user interface; 

FIG. 5 is a block diagram illustrating details of the work 
manager of FIG. 3; 

FIG. 6 illustrates an example musical work file; 

FIG. 7 is a block diagram illustrating details of the player client 
of FIG. 1; 

FIG. 8 is a block diagram illustrating details of the player 
system of FIG. 7; 

FIG. 9 is a flowchart illustrating a method for composing a 
musical work; 
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FIG. 10 is a flowchart illustrating details of the FIG. 9 step of 
compiling the musical work file; and 

FIG. 11 is a flowchart illustrating a method for performing a 
channel of the musical work file. 

5 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 
FIG. 1 is a block diagram of a music network system 100 in 
accordance with the present invention. Music network system 100 
includes a composer server 110 coupled via a computer network 120 

10 such as the Internet to a player client 125. Composer server 110 
receives input control signals representing sound via a Musical 
Instrument Digital Interface (MIDI) input device 105 such as a 
conventional synthesizer keyboard, and uses a composer sound 
output device 115 to convert the control signals to sound. Player 

15 client 125 may receive the control signals and other data from 
composer server 110 via computer network 120 or via a compact 
disk (CD) 135, and uses a client sound output device 130 to convert 
the control signals and other data to sound. It will be appreciated 
that the player client 125 may also be connected to a MIDI input 

20 device 105, in which case the player client 125 can be configured to 
operate as another composer server 110. 
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FIG. 2 is a block diagram illustrating details of composer server 
110 including a Central Processing Unit (CPU) 205, such as an Intel 
Pentium® microprocessor or a Motorola Power PC® microprocessor, 
5 coupled to a signal bus 225. Composer server 110 further comprises 
a Random Access Memory (RAM) 210, a Graphical User Interface 
(GUI) 215 which includes input devices such as a keyboard and a 
mouse and an output device such as a Cathode Ray Tube (CRT) 
display, and a disk drive 220, each coupled via signal bus 225 to 

10 CPU 205. Composer server 110 further includes a communications 
interface 230 coupled between signal bus 225 and computer 
network 120 (FIG. 1), and a data storage device 235 such as a 
magnetic disk coupled to signal bus 225. 

An operating system 260 includes a program that controls 

15 processing by CPU 205, and is typically stored in data storage device 
235 and loaded into RAM 210 for execution. A composition system 
240 contains programs for creating synthesizer files such as a sound 
bank 250, a sample bank 252 and an effect bank 254, programs for 
using the synthesizer files to generate music sequences, programs 

20 for synthesizing music from the sequences, and programs for 

generating an integral musical work file 255 to be forwarded to the 
player client 125. Composition system 240 also may be stored in 



PATENT 

data storage device 235 and loaded into RAM 210 for execution by 
CPU 205. 

Sound bank 250 is a data file containing at least the instrument 
sounds needed by the composer, and is typically stored in data 
5 storage device 235 but may be stored at some predetermined 

location in computer network 120. Sample bank 252 is a data file 
containing audio clips of specific sounds such as a dog's bark, a cat's 
meow, a water drop, etc., and may be stored in data storage device 
235 or at some predetermined location in computer network 120. 

10 Effect bank 254 is a data file containing effect algorithms and effect 
parameters for creating musical effects such as reverberation, 
chorus, etc., and may also be stored in data storage device 235 or at 
some predetermined location in computer network 120. A 
synthesizer driver 245 is a program for controlling performance of 

15 the musical sequence on composer sound output device 115 (FIG. 1), 
and also may be stored in data storage device 235 and loaded into 
RAM 210 for execution by CPU 205. 

FIG. 3 is a block diagram illustrating details of composition 
20 system 240, which includes a synthesizer engine 305 coupled to 

signal bus 225 (FIG. 2) for processing input control signals from input 
device 105. These input control signals may include instrument 
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sound selections, music sequence data, initial topology such as initial 
mix and effect parameters, and topology changes such as mix and 
effect parameter changes. 

Synthesizer engine 305 via sequencer 325 converts the input 
5 control signals or sequence control signals to a raw musical data 330 
audio sequence. Synthesizer engine 305 processes the raw musical 
data 330 audio sequence based on the composer's instrument sound 
selections, and delivers the processed sequence to mixer 310. Mixer 
310 uses the initial topology information to configure mixer 310 and 

10 the musical effects 313 such as reverb 315 and chorus 320. Example 
mix variables for a stereo mixer 310 include synthesizer volume, 
synthesizer pan, audio volume, audio pan, audio reverb send, audio 
chorus send, reverb return level, reverb return balance, chorus 
return level, chorus return balance, etc. It will be appreciated that 

15 the characteristics of reverb 315 and chorus 320 are defined by the 
effect algorithms contained in effect bank 254, which may be created 
or edited by an effects editor 322. The composer via MIDI input 
device 105 may modify the effect parameters to modify the effects 
313. Mixer 310 then mixes the effects 313 into the processed raw 

20 musical data 330 audio sequence, and forwards the mix to 
synthesizer driver 245 for conversion to sound. 
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Synthesizer engine 305 also forwards to sequencer 325 the 
input control signals representing the MIDI-based musical sequences 
and topology changes created by a composer. Sequencer 325 
compiles and stores the signals in a predetermined time-based 
5 format as raw musical data 330, which may be stored in data storage 
device 235 or on a compact disk 135. Sequencer 325 preferably 
includes a sequencer editor 335 for enabling modifications such as 
cut, paste, repeat, modify instrument sound selection, change pitch, 
change topology, etc. of stored raw musical data 330. Synthesizer 

10 engine 305 can retrieve the modified raw musical data 330 for 
conversion via mixer 310 to sound. 

Input control signals may also include work links, which 
reference work link data such as previously created sounds, effects, 
samples, etc. Work link data may be stored at locations anywhere in 

15 network system 100. Accordingly, to incorporate instrument sounds, 
synthesizer engine 305 retrieves the composer-selected instruments 
sounds either from local sound bank 250 or from the locations in 
system 100 referenced by work links. Similarly, to incorporate 
samples, the synthesizer engine 305 retrieves the samples either 

20 from the local sample bank 252 or from the locations in system 100 
referenced by work links. To incorporate effects, the synthesizer 
engine 305 retrieves the effects either from local effect bank 254 or 
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from the locations in system 100 referenced by work links. 
Synthesizer engine 305 temporarily stores work linked sounds into 
sound bank 250, work linked effects into effect bank 254 and work 
linked samples into sample bank 252 for easy and efficient playback. 
5 Composition system 240 further includes a sound editor 340 

coupled to sound bank 250 for enabling a composer to add 
instrument sounds to, delete instrument sounds from or modify 
instrument sounds contained in sound bank 250. Creating and 
modifying instrument sounds may be implemented by processing 

10 sounds synthetically, by digitally modifying a sound sample or by a 
combined method. Sound editor 340 is described in greater detail 
with reference to FIGs. 4a, 4b, 4c and 4d. 

Composition system 240 also includes a work manager 345 
which reformats, imports and exports sound bank 250, sample bank 

15 252, effect bank 254 and raw musical data 330 into a predetermined 
file format, and stores the re-formatted data to a musical work file 
255. Work manager 345 further maintains file legitimacy, allows 
real-time edit buffering and file maintenance, and in general allows 
updated industry standard tools to export their data into the present 

20 system 100 without the responsibility of maintaining the integrity of 
musical work file 255. Work manager 345 is described in greater 
detail with reference to FIG. 5. 
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Because, in addition to the raw musical data 330, musical work 
file 255 includes sound bank 250, sample bank 252 and effect bank 
254, musical system 100 provides all the information needed to 
perform the musical piece. Thus, system independence is achieved, 

5 That is, unlike systems implementing standard MIDI, composition 
system 240 forwards data representing the instrument sounds and 
topology information needed to perform the piece. Unlike systems 
implementing General MIDI, composition system 240 enables 
creation and modification of an infinite variety of custom instrument 

10 or non-instrument sounds and thus is not limited to a predetermined 
set of 128 instruments (plus percussion). Predictable consumer MIDI 
performance, which was hitherto impossible to achieve, is now 
rendered certain by this invention. 

It will be further appreciated that since the entire composition 

15 system 240 is implemented in software, it is possible to maintain any 
number of channels and any number of tracks, but, of course, limited 
by processor speed, system bandwidth and memory availability. In 
the preferred embodiment, composition system 240 includes an 
equal number of channels and tracks so that each channel can be 

20 stored on a single track. For example, composition system 240 may 
manage 1024 channels and 1024 tracks. 
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FIGs. 4a, 4b, 4c and 4d illustrate four alternative types of 
sound editors 340. Namely, FIG. 4a illustrates a sound editor 340' for 
generating a synthetic voice. Sound editor 340' includes an oscillator 

5 405 for receiving a trigger and responsively generating a sound 

signal, a filter 410 coupled to oscillator 405 for modifying the sound 
signal, and an amplifier 415 coupled to filter 410 for controlling the 
sound signal. Sound editor 340' further includes a real-time 
modulation block 420 coupled to oscillator 405, filter 410 and 

10 amplifier 415 for receiving the trigger signal and animating the 
behavior of oscillator 405, filter 410 and amplifier 415. FIG. 4b 
illustrates a waveform captured by a digital sound editor 340" which 
uses Pulse Code Modulation (PCM) techniques to convert the analog 
sample to a digital signal. FIG. 4c illustrates a combined sound editor 

15 340"' topology which includes a digital audio sample 425 coupled to 
a processing block 430 for synthetically modifying digital audio 
sample 425. FIG. 4d shows a sound editor user interface 340"" used 
to combine individual sounds into practical and expressive 
instruments. In addition to arranging instruments arbitrarily in the 

20 space of loudness and pitch, these editors typically provide further 
parameterization of each instrument for volume, pan, transposition, 
delay and effects processing at a global level. 
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FIG. 5 is a block diagram illustrating details of work manager 
345, which includes a header utilities engine 505, a data 
Input/Output (I/O) engine 510 and a work certifier 515. 

5 Header utilities engine 505 assigns and stores in musical work 

file 255 header data including musical work file identification (ID) 
information such as a work file name, the composer's name, a serial 
number, a composition system 240 version number, etc. Header 
utilities engine 505 may also compute and store in musical work file 

10 255 the number of channels needed by player client 125 to perform 
the musical work. 

Data I/O engine 510 retrieves, reformats and stores sound 
bank 250, sample bank 252, effect bank 254 and raw musical data 
330 into musical work file 255. Data I/O engine 510 may also use 

15 resource data 513 to compute and store initialization data indicating 
initial channel parameters, an approximation of the time needed to 
download sounds from sound bank 250, and a sequential list of 
topology changes needed during performance of the musical work. 
Work certifier 515 checks for data integrity and authenticates 

20 musical work file 255 by, for example, stamping the file 255 with a 
certificate, password key or encryption key. Thus, a composer server 
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110 may authenticate the musical work file 255 and only an 
authorized player client 125 may perform the work. 



FIG. 6 illustrates an example musical work file 255, which 
5 includes work file ID 605, initialization data 610, a copy of sound 
bank 250, a copy of sample bank 252, a copy of effect bank 254, a 
copy of raw musical data 330 and certification 635. Raw musical 
data 330 includes the music sequence 615, the effect parameter 
changes 620, the mix parameter changes 625 and work links 630. 

10 Although in this embodiment a copy of the work link data referenced 
by work links 630 is not included as part of musical work file 255, 
an equivalent embodiment may include the copy. In this 
embodiment, player client 125 may download the needed work link 
data in real time from its source, e.g., from composer server 110 or 

15 from computer network 120. It will be appreciated that the 
different tracks and thus the different channels may be stored 
separately as raw musical data 330. 

FIG. 7 is a block diagram illustrating details of player client 125 
20 which includes a CPU 705, such as an Intel Pentium® microprocessor 
or a Motorola Power PC® microprocessor, coupled to a signal bus 725. 
Player client 125 further comprises RAM 710, a GUI 715 which 
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includes input devices such as a keyboard and mouse and an output 
device such as a Cathode Ray Tube (CRT) display, and a CD drive 
720, each coupled via signal bus 725 to CPU 705. Player client 125 
further includes a communications interface 730 coupled between 
5 signal bus 725 and computer network 120 (FIG. 1), and a data 
storage device 735 such as a magnetic disk coupled to signal bus 
725. 

An operating system 750 is a program that controls processing 
by CPU 705, and is typically stored in data storage device 735 and 

10 loaded into RAM 710 for execution. A player system 740 includes 
programs for decoding musical work file 255, programs for setting 
the topology and programs for controlling the performance of the 
musical work. Player system 740 may be stored in data storage 
device 735 and loaded into RAM 710 for execution by CPU 705. 

15 Upon receipt, musical work file 255 may be stored in data storage 
device 735 and loaded into RAM for easy access by player system 
740. Player system 740 is described in greater detail with reference 
to FIG. 8. A synthesizer driver 745 is a program for controlling client 
sound output device 130 (FIG. 1), and is also typically stored in data 

20 storage device 735 and loaded into RAM 710 for execution by CPU 
705. 
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FIG. 8 is a block diagram illustrating player system 740, which 
includes a certifier 805 for examining certification 640 to 
authenticate musical work file 255 and to determine the rights of 

5 player client 125 to perform musical work file 255. The certifier 805 
also enables gathering needed work link data which is referenced by 
work links contained in raw musical data 330. Player system 740 
includes a sequencer 810 coupled to certifier 805 for playing the raw 
musical data 330 contained in musical work file 255. 

10 Player system. 740 includes a synthesizer engine 815 coupled 

to sequencer 810 for adding instrument sounds to the music 
sequence 615 by retrieving the composer-selected instrument 
sounds from sound bank 250 contained in musical work file 255 or 
from the locations referenced by the work links 630. Player system 

15 740 further includes, coupled between synthesizer engine 815 and 
synthesizer driver 745, a mixer 820 configured according to mix 
parameters 625; and includes musical effects including reverb 825 
and chorus 830 coupled to mixer 820 which are configured according 
to algorithms in effect bank 254 and corresponding effect 

20 parameters 620. Mixer 820 mixes the music sequence 615 and the 
effects. It will be appreciated that player system 740 operates in 
conjunction with operating system 750 (for example, various 
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versions of Windows by Microsoft Corporation) for loading and 
unloading sounds from data storage device 235. 



FIG. 9 is a flowchart illustrating a preferred method 900 for 
5 composing a musical work. Method 900 begins with step 910 by 
sound editor 340 enabling creation of sounds for storage in sound 
bank 250. Sound editor 340 in step 915 enables modification of 
sounds stored in sound bank 250, possibly to create new sounds. 
The composer via MIDI input device 105 in step 920 selects sounds 
10 for the instruments to be played on a first channel by player client 
125. Step 920 may include selecting one of the sounds from sound 
bank 250, or selecting a previously created sound from a location 
somewhere within network 120 and adding a work link 630 to 
reference that location. It will be appreciated that step 920 may 
15 further include selecting a fall-back sound, such as one of GM sounds 
1-128, to use if the custom sound is unavailable at the start of the 
sequence. 

Effects editor 322 in step 925 may be used to create effects for 
storage in effect bank 254, and in step 930 enables modification of 
20 the effects stored in effect bank 254 possibly to create new effects. 
The composer via MIDI input device 105 in step 935 selects the 
effects to be used by player client 125 on the first channel. Step 925 

-18- 



PATENT 

may include selecting one of the effects from effect bank 254, or 
selecting a previously created effect from a location somewhere 
within network 120 and adding a work link 630 to reference that 
location. 

5 Sequencer 325 in step 940 records a music sequence including 

topology changes as part of raw musical data 330 to be used on the 
first channel. Step 940 includes receiving other input control signals 
such as intonation and expression information from MIDI input 
device 105 and passing the signals through synthesizer engine 305 to 

10 sequencer 325 for storage. Sequencer editor 335 in step 945 enables 
the composer to edit raw musical data 330, e.g., to edit the music 
sequences, to edit pitches, to edit effects, to copy, to paste, etc. 

Sequencer 325 in step 950 retains the music sequence data 
615 including the composer-selected instrument sounds, the 

15 performance, the mixer and effect changes, etc. as raw musical data 
330. In step 955, a determination is made whether to record musical 
data to another channel. If so, then method 900 returns to step 910. 
Otherwise, work manager 345 compiles sound bank 250, sample 
bank 252, effect bank 254 and all channels of raw musical data 330 

20 into a musical work file 255. Step 960 is described in greater detail 
with reference to FIG. 10. Method 900 then ends. 
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FIG. 10 is a flowchart illustrating details of step 960 (FIG. 9), 
which begins by header utilities engine 505 in step 1005 creating 
and storing to musical work file 255 a work file ID for identifying the 
musical work. Data I/O engine 510 in step 1010 uses resource data 
513 and raw musical data 330 to compute initialization data 610 
representing the initial state of the music sequence as created by the 
composer, and stores the initialization data 610 to musical work file 
255. Initialization data 610 includes the initial topology parameters. 
The data I/O engine 510 retrieves and stores in step 1015 the sound 
bank 250, in step 1018 the sample bank 252 and in step 1022 the 
effect bank 254 to musical work file 255. The data I/O engine 510 in 
step 1025 retrieves and stores raw musical data 330, which includes 
music sequence 615, effect parameter changes 620, mix parameter 
changes 625 and work links 630 for all channels, to musical work file 
255. In step 1030, work certifier 520 adds certification 640 to 
musical work file 255 so that player client 125 can authenticate and 
verify right to perform musical work file 255. Step 960 then ends. 

FIG. 11 is a flowchart illustrating a method 1100 for 
performing a channel of musical work file 255. Method 1100 begins 
with step 1105 by communications interface 730 or CD drive 720 of 
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player client 125 receiving musical work file 255. Certifier 805 in 
step 1110 examines certification 640 to determine whether player 
client 125 is certified to perform the musical work file 255. If not, 
then method 1100 ends. Otherwise, certifier 805 forwards at least a 

5 portion of a first channel contained in musical work file 255 to 
sequencer 810, which in step 1115 forwards the corresponding 
channel portion to synthesizer engine 815. 

For the first channel portion, synthesizer engine 815 in step 
1120 downloads the composer-selected initial mix parameters 625 

10 from raw musical data 330 of musical work file 255 to mixer 820, 
and in step 1125 downloads the composer-selected initial effect 
parameters 620 from raw musical data 330 of musical work file 255 
to the selected effects. Synthesizer 815 in step 1130 retrieves from 
sound bank 250 the instrument sounds referenced by the music 

15 sequence 615, and in step 1135 downloads any instruments, mixes, 
effects or other work link data from the locations specified by work 
links 630. 

Synthesizer engine 815 in step 1136 determines whether all 
sounds needed to perform the musical work are available. If so, then 
20 method 1100 proceeds to step 1140. If a custom sound is 

unavailable, synthesizer engine 1136 determines whether a fall-back 
sound such as a GM sound is available to replace it. If not, then 
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synthesizer engine in step 1139 posts an error message and method 
1100 then ends. Otherwise, method 1100 references the available 
fall-back sounds and proceeds to step 1140. 

In step 1140, synthesizer 815 synthesizes and forwards the 

5 corresponding channel portion to synthesizer driver 745, which in 
conjunction with client sound output device 130 (FIG. 1) converts the 
synthesized channel portion to sound. In step 1145, sequencer 810 
determines whether musical work file 255 includes another channel 
portion to be performed. If so, then method 1100 returns to step 

10 1115. Otherwise, method 1100 ends. 

The foregoing description of the preferred embodiments of the 
invention is by way of example only, and other variations of the 
above-described embodiments and methods are provided by the 

15 present invention. Components of this invention may be 

implemented using a programmed general purpose digital computer, 
using application specific integrated circuits, or using a network of 
interconnected conventional components and circuits. The 
embodiments described herein have been presented for purposes of 

20 illustration and are not intended to be exhaustive or limiting. Many 
variations and modifications are possible in light of the foregoing 
teaching. The system is limited only by the following claims. 
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WHAT IS CLAIMED IS : 
11. A composition system comprising: 

2 a sound bank containing at least one instrument sound; 

3 an input device for receiving music control signals; 

4 a sequencer coupled to the input device for storing the music 

5 control signals; and 

6 a work manager coupled to the sound bank and to the 

7 sequencer for generating a musical work file containing the music 

8 control signals and at least a portion of the sound bank. 

1 2. The composition system of claim 1 further comprising a sound 

2 editor for modifying the sound bank. 

1 3. The composition system of claim 2 wherein modifying the 

2 sound bank includes adding instrument sounds to, deleting an 

3 instrument sound from and modifying an instrument sound 

4 contained in the sound bank. 

1 4. The composition system of claim 1 wherein the input device is 

2 a MIDI input device. 
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1 5. The composition system of claim 4 wherein the input device is 

2 a computer keyboard. 

1 6. The composition system of claim 1 wherein the work manager 

2 includes a header utilities engine for generating a header to the 

3 musical work file. 

1 7. The composition system of claim 6 wherein the header includes 

2 a title, a serial number and the composer's name. 

1 8. The composition system of claim 1 wherein the work manager 

2 includes a work certifier for certifying the musical work file. 

1 9. The composition system of claim 1 wherein the work manager 

2 includes a data I/O engine for storing the at least a portion of the 

3 sound bank and the music control signals into the musical work file. 

1 10. The composition system of claim 9 wherein the music control 

2 signals include a work link, and the data I/O engine further stores 

3 the work link to the musical work file. 
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1 11. The composition system of claim 9 wherein 

2 the music control signals include a music sequence, mix 

3 changes and effect changes; and 

4 the data I/O engine further stores the music sequence, the mix 

5 changes and effect changes to the musical work file. 

1 12. The composition system of claim 11, 

2 further comprising an effect bank storing effect and mix 

3 algorithms; and 

4 wherein the data I/O engine stores the effect bank to the music 

5 work file. 



1 13. The composition system of claim 1, 

2 further comprising a sample bank; and 

3 wherein the work manager stores the sample bank to the 

4 music work file. 
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1 14. The composition system of claim 1 further comprising 

2 a synthesizer engine coupled to the input device for processing 

3 the music control signals based on the instrument sounds contained 

4 in the sound bank; 

5 a mixer coupled to the synthesizer engine for mixing effects 

6 with the processed music control signals; and 

7 a speaker system coupled to the mixer for converting the 

8 mixed music control signals to sound. 

1 15. The composition system of claim 14 wherein 

2 the music control signals include a work link specifying a 

3 location storing work link data; 

4 the data I/O engine further stores the work link to the musical 

5 work file; and 

6 the synthesizer engine retrieves the work link data stored at 

7 the location specified by the work link. 
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1 16. A method comprising the steps of: 

2 receiving music control signals; 

3 receiving at least a portion of a sound bank containing at least 

4 one instrument sound; and 

5 storing the music control signals and received sound bank 

6 portion as a musical work file. 

1 17. The method of claim 16 further comprising the step of 

2 modifying the sound bank. 

1 18. The method of claim 17 wherein the step of modifying the 

2 sound bank includes adding instrument sounds to, deleting an 

3 instrument sound from and modifying an instrument sound 

4 contained in the sound bank. 

1 19. The method of claim 16 wherein the step of receiving music 

2 control signals is achieved using a MIDI keyboard. 

1 20. The method of claim 16 further comprising the step of 

2 generating a header to the musical work file. 
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1 21. The method of claim 20 wherein the header includes a title, a 

2 serial number and the composer's name. 

1 22. The method of claim 16 further comprising the step of 

2 certifying the musical work file. 

1 23. The method of claim 22 wherein the music control signals 

2 include a music sequence, mix changes and effect changes, and 

3 further including the step of storing the music sequence, the mix 

4 changes and the effect changes to the musical work file. 

1 24. The method of claim 23 wherein the music control signals 

2 include a work link, and further including the step of storing the 

3 work link to the musical work file. 

1 25. The method of claim 16 further comprising the steps of 

2 processing the music control signals based on the instrument 

3 sounds contained in the sound bank; 

4 mixing effects with the processed music control signals; and 

5 converting the mixed music control signals to sound. 
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1 26. A composition system comprising: 

2 means for receiving music control signals; 

3 means for receiving at least a portion of a sound bank 

4 containing at least one instrument sound; and 

5 means for storing the music control signals and received sound 

6 bank portion as a musical work file. 



1 27. A computer-readable medium storing program code for causing 

2 a computer to perform the steps of: 

3 receiving music control signals; 

4 receiving at least a portion of a sound bank containing at least 

5 one instrument sound; and 

6 storing the music control signals and received sound bank 

7 portion as a musical work file. 
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1 28. A player system comprising: 

2 an input terminal for receiving a musical work file containing 

3 topology information, music sequence data and a sound bank which 

4 includes at least one instrument sound; 

5 a synthesizer coupled to the input terminal for processing the 

6 music sequence data based on the topology information and the 

7 sound bank; and 

8 a speaker system coupled to the synthesizer for converting the 

9 processed music sequence data to sound. 

1 29. The player system of claim 28 wherein the input terminal 

2 includes a CD drive. 

1 30. The player system of claim 28 wherein the input terminal 

2 includes a network communications interface. 

1 31. The player system of claim 28 further comprising a mixer for 

2 mixing effects with the processed music sequence data. 

1 32. The player system of claim 31 wherein the topology 

2 information includes initial effect parameters for controlling the 

3 effects. 
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1 33. The player system of claim 31 wherein the topology 

2 information further includes initial mix parameters for controlling 

3 the mixer. 

1 34. The player system of claim 31 wherein 

2 the music sequence data includes a work link specifying a 

3 location storing work link data; and 

4 the synthesizer engine retrieves the work link data referenced 

5 by the work link. 

1 35. The player system of claim 28 further comprising a certifier for 

2 certifying right of the player system to convert the processed music 

3 sequence to sound. 

1 36. A method comprising the steps of: 

2 receiving a musical work file containing topology information, 

3 music sequence data and a sound bank which includes at least one 

4 instrument sound; 

5 processing the music sequence data based on the topology 

6 information and the sound bank; and 

7 converting the processed music sequence data to sound. 
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1 37. The method of claim 36 wherein the step of receiving a musical 

2 work file is achieved by a CD drive. 

1 3 8. The method of claim 37 wherein the step of receiving a musical 

2 work file is achieved by a network communications interface. 

1 39. The method of claim 36 further comprising the step of mixing 

2 effects with the processed music sequence data. 

1 40. The method of claim 39 wherein the topology information. 

2 includes initial effect parameters for controlling the effects. 

1 41. The method of claim 39 wherein the topology information 

2 further includes initial mix parameters for controlling the step of 

3 mixing. 

1 42. The method of claim 36 

2 wherein the music sequence data includes a work link 

3 specifying a location storing work link data; and 

4 further comprising the step of retrieving the work link data 

5 from the location specified by the work link. 
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1 43. The method of claim 36 further comprising the step of 

2 certifying right of the player system to convert the processed music 

3 sequence to sound. 



1 44. A player system comprising: 

2 means for receiving a musical work file containing topology 

3 information, music sequence data and a sound bank which includes 

4 at least one instrument sound; 

5 means for processing the music sequence data based on the 

6 topology information and the sound bank; and 

7 means for converting the processed music sequence data to 

8 sound. 



1 45. A computer-readable medium storing program code for causing 

2 a computer to perform the steps of: 

3 receiving a musical work file containing topology information, 

4 music sequence data and a sound bank which includes at least one 

5 instrument sound; 

6 processing the music sequence data based on the topology 

7 information and the sound bank; and 

8 converting the processed music sequence data to sound. 
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SYSTEM AND METHOD FOR GENERATING. DISTRIBI JTINO, STORING 
AND PERFORMING MUSICAL WORK FILES 



ABSTRACT OF THE DISCLOSURE 
5 A composition and playback system includes a sound bank 

containing at least one instrument sound, an input device for 
receiving music control signals, a sequencer coupled to the input 
device for storing the music control signals, and a work manager 
coupled to the sound bank and to the sequencer for generating a 

10 musical work file containing the music control signals and at least a 
portion of the sound bank. The system further includes a 
synthesizer engine coupled to the input device for processing the 
music control signals based on the instrument sounds contained in 
the sound bank, a mixer coupled to the synthesizer engine for mixing 

15 effects with the processed music control signals, and a speaker 

system coupled to the mixer for converting the mixed music control 
signals to sound. 
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